Pass the hash is a hacking technique that allows an attacker to authenticate to a remote server/service by using the underlying NTLM and/or LM hash of a user's password, instead of using the cleartext password as is normally the case.
After an attacker obtains a valid user name and user password hashes values (somehow, using different methods and tools), he or she is then able to use that information to authenticate to a remote server/service using NTLM authentication without the need to brute-force the hashes to obtain the cleartext password (as it was required before this technique was published).
This technique can be performed against any server/service accepting NTLM authentication, whether it is running on a machine with Windows, *Unix, or any other operating system.
Contents |
On systems/services using NTLM authentication, users' passwords are never sent in cleartext over the wire. Instead, they are provided to the requesting system, such as a domain controller, as a hash in a response to a challenge-response authentication scheme.[1]
Native Windows applications ask users for the cleartext password, then call APIs like LsaLogonUser[2] that convert that password to one or two hash values (the LM and/or NT hashes) and then send that to the remote server during NTLM authentication.[Notes 1][3] Observation of this mechanism has shown that the cleartext password is not required to complete network authentication successfully, only the hashes are needed.
If an attacker has the hashes of a user's password, he/she does not need to brute-force the cleartext password; he/she can simply use the hash of an arbitrary user account that he has harvested and execute a side channel attack to authenticate against a remote system and impersonate that user.[4] In other words, from an attacker's perspective, hashes are functionally equivalent to the original passwords that they were generated from.
The pass the hash technique was originally published by Paul Ashton in 1997[4] and consisted of a modified Samba SMB client that accepted user password hashes instead of cleartext passwords (Later versions of Samba and other third-party implementations of the SMB and NTLM procotols also included the functionality).
This implementation of the technique was based on an SMB stack created by a third-party (e.g.: Samba and others), and for this reason suffered from a series of limitations from a hacker's perspective, including limited and/or partial functionality: The SMB protocol has continued to evolve over the years, this means that third-parties creating their own implementation of the SMB protocol need to implement changes and additions to the protocol after they are introduced by newer versions of Windows/SMB (historically by reverse engineering, which is very complex and time consuming). This means that even after performing NTLM authentication successfully using the pass the hash technique, tools like Samba's SMB client might not have implemented the functionality the attacker might want to use. This meant that it was difficult to attack Windows programs that use DCOM/RPC.
Also, because attackers were restricted to using third-party clients when carrying out attacks, it was not possible to use built-in Windows applications, like Net.exe or the Active Directory Users and Computers tool amongst others, because they asked the attacker/user to enter the cleartext password to authenticate, and not the corresponding password hash value.
In 2008, Hernan Ochoa published a tool called the "Pass-the-Hash Toolkit"[5] that allowed 'pass the hash' to be performed natively on Windows. It allowed the user name, domain name, and password hashes cached in memory by the Local Security Authority to be changed at runtime after a user was authenticated — this made it possible to 'pass the hash' using standard Windows applications, and thereby to undermine fundamental authentication mechanisms built into the operating system.
The tool also introduced a new technique which allowed dumping password hashes cached in the memory of the lsass.exe process (not in persistent storage on disk), which quickly became widely used by penetration testers (and attackers). This hash harvesting technique is more advanced than previously used techniques (e.g. dumping the local Security Accounts Manager database (SAM) using pwdump and similar tools), mainly because usernames/domain/password hashes values stored in memory could include credentials of domain users (and domain administrators) that logged into the machine. For example, the hashes of authenticated domain users that are not stored persistently in the local SAM can also be dumped. This makes it possible for a penetration tester (or attacker) to compromise a whole Windows domain after compromising a single machine that was a member of that domain. Furthermore, the attack can be implemented instantaneously and without any requirement for expensive computing resources to carry out a brute force attack.
This toolkit has subsequently been superseded by "Windows Credential Editor", which extends the original tool's functionality and operating system support.[6][7] Some antivirus vendors classify the toolkit as malware.[8][9]
Before an attacker can carry out a pass-the-hash attack, he/she must obtain the password hashes of the target user accounts. To this end, penetration testers/attackers can harvest password hashes using a number of different methods:
Any system using LM or NTLM authentication in combination with any protocol (SMB, FTP, RPC, HTTP etc.) is at risk from this attack.[1] The exploit is very difficult to defend against, because there are countless exploits in Windows and applications running on Windows that can be used by an attacker to elevate their privileges and then carry out the hash harvesting that facilitates the attack. Furthermore, it may only require one machine in a Windows domain to not be configured correctly or be missing a security patch for an attacker to find a way in. A wide range of penetration testing tools are furthermore available to automate the process of discovering a weakness on a machine.
There is no single defence against the technique, so standard defence in depth practices apply[10] - for example use of firewalls, intrusion prevention systems, 802.1x authentication, IPsec, antivirus software, full disk encryption, reducing the number of people with elevated privileges,[11] pro-active security patching[12] etc. Preventing Windows from storing cached credentials may limit attackers to obtaining hashes from memory, which usually means that the target account must be logged into the machine when the attack is executed.[13] Allowing domain administrators to log into systems that may be compromised or untrusted will create a scenario where the administrators' hashes become the targets of attackers; limiting domain administrator logons to trusted domain controllers can therefore limit the opportunities for an attacker.[10] The principle of least privilege suggests that a least user access (LUA) approach should be taken, in that users should not use accounts with more privileges than necessary to complete the task at hand.[10] Configuring systems not to use LM or NTLM can also strengthen security, but newer exploits are able to forward Kerberos tickets in a similar way.[14] Limiting the scope of debug privileges on system may frustrate some attacks that inject code or steal hashes from the memory of sensitive processes.[10]